php - Laravel 5.2 迁移 : Cannot add foreign key of char data type
全部标签 我希望从schema.rb生成一个迁移文件。是否可以?目前我有很多迁移文件,想将所有内容合并到一个主迁移文件中。我还认为我可能在某个时候不小心删除了一个迁移文件。谢谢你的帮助 最佳答案 您可以将schema.rb复制并粘贴到迁移中并回溯它(例如更改日期),这样现有的数据库就不会运行它。创建此迁移后,您可以删除所有旧迁移。我不同意Andrew不应该删除迁移的观点。迁移总是基于模型类的变化而意外中断,修复它们非常重要。由于我确定您正在使用版本控制,因此如果您需要它们以供引用,您可以随时回顾历史。
我使用railsgeneratemigrations命令在我的rails应用程序中创建了一个表。这是迁移文件:classCreateListings然后我想将纬度和经度存储为整数我试着跑:railsgeneratemigrationchangeColumnType该文件的内容是:classChangeColumnType我原以为列类型会发生变化,但是rake被中止并出现了以下错误消息。我想知道为什么这没有通过?我在我的应用程序中使用postgresql。rakedb:migrate==ChangeColumnType:migrating=========================
我在迁移中有以下内容:create_table:model_with_a_long_namedo|t|t.references:other_model_with_an_equally_long_name,index:trueend对于Postgres,这会产生一个名称太长的索引。有没有办法手动指定索引名称(不用单独添加整数列和索引)?类似下面的内容:create_table:model_with_a_long_namedo|t|t.references:other_model_with_an_equally_long_name,index:true,index_name:'model_
当我在postgresql上的Rails应用程序中运行我的迁移时,我得到了以下通知NOTICE:CREATETABLEwillcreateimplicitsequence"notification_settings_id_seq"forserialcolumn"notification_settings.id"NOTICE:CREATETABLE/PRIMARYKEYwillcreateimplicitindex"notification_settings_pkey"fortable"notification_settings"我的迁移文件包含088_create_notificati
我了解到add_column有一个:after选项来设置插入列的位置。太糟糕了,我才知道它:在添加了一堆之后。如何编写迁移以简单地对列进行重新排序? 最佳答案 当使用MySQL时,您可以调用change_column,但是您必须重复列类型(只需从您的其他迁移中复制并粘贴它):defupchange_column:your_table,:some_column,:integer,after::other_columnend或者如果您必须对一个表中的多个列重新排序:defupchange_table:your_tabledo|t|t.c
基本上只是检查以确保设置了url参数。我如何在PHP中做到这一点:if(isset($_POST['foo'])&&isset($_POST['bar'])){}这是RoR中isset()的粗略/最佳等价物吗?if(!params['foo'].nil?&&!params['bar'].nil?)end 最佳答案 更接近的匹配可能是#present?#returnstrueifnotnilandnotblankparams['foo'].present?还有一些其他的方法#returnstrueifnilparams['foo'].
使用railsgeneratemigrationAddClientToUser创建迁移文件后,我可以像这样编辑迁移文件:classAddClientToUser这是反转迁移中添加的引用列的正确方法吗? 最佳答案 导轨4.2.1railsgmigrationRemoveClientFromUsersclient:references将生成类似的迁移:classRemoveClientFromUser此外,您可以通过添加以下方式自由添加另一个或其他引用:add_reference:users,:model_name,index:true
我有以下迁移,我希望能够检查当前与环境相关的数据库是否为mysql数据库。如果是mysql,那么我想执行特定于数据库的SQL。我该怎么做?classAddUsersFb 最佳答案 更短的通话时间ActiveRecord::Base.connection.adapter_name=='MySQL' 关于ruby-on-rails-如何检查Rails迁移中的数据库类型?,我们在StackOverflow上找到一个类似的问题: https://stackoverfl
我的意思是字典中的“rebase”,而不是git定义...我有一个大型的、长期运行的Rails项目,其中有大约250个迁移,管理所有这些变得有点笨拙。也就是说,我确实需要一个基础来在运行测试时从中清除和重建我的数据库。所以这些里面包含的数据很重要。有没有人有任何策略可以说,在设定点转储架构-归档所有旧迁移并重新开始新迁移。显然我可以使用rakeschema:dump-但实际上我需要一种方法让db:migrate首先加载模式,然后开始运行其余的迁移。我想继续使用迁移,因为它们在开发中非常有用,但是,我无法回过头来编辑2007年的迁移,所以保留它似乎很愚蠢。 最
我的用户表登录列是String类型,限制为40个字符。现在我打算将限制增加到55个字符。任何人请让我知道我们如何通过使用ROR迁移来增加此限制。谢谢,沙湾 最佳答案 classYourMigration55enddefdownchange_column:users,:login,:string,:limit=>40endend 关于ruby-on-rails-rails迁移:HowtoincreasecolumndatatypesizebyusingRORmigration,我们在Sta